# Computer Organization

# Single-cycle CPU

Sunghwa Lee (<u>sunghwa2@snu.ac.kr</u>)
High Performance Computer System (HPCS) Lab
March 29, 2017

#### Goals

- Understand CPU structure.
- Understand the roles of the datapath & the control unit.
- Implement the datapath (single-cycle CPU) using Verilog.



#### CPU structure: ISA

- Instruction Set Architecture
  - Programmer visible state
  - User manual of the computer
- We will use TSC ISA instead of complicated MIPS ISA
  - 16-bit RICS ISA
  - Similar to MIPS, but more simplified.
  - Refer to the manual on the eTL board.

#### TSC ISA

- Instruction types
  - R, I, and J-format
  - Similar to MIPS



#### CPU structure: TSC ISA

- Instruction Opcodes
  - Refer to the manual!

| Opcode | Function Code                                                                      | Format                                                              |
|--------|------------------------------------------------------------------------------------|---------------------------------------------------------------------|
| 15     | 0                                                                                  | R                                                                   |
| 15     | 1                                                                                  | R                                                                   |
| 15     | 2                                                                                  | R                                                                   |
| 15     | 3                                                                                  | R                                                                   |
| 15     | 4                                                                                  | R                                                                   |
| 15     | 5                                                                                  | R                                                                   |
| 15     | 6                                                                                  | R                                                                   |
| 15     | 7                                                                                  | R                                                                   |
| 4      | _                                                                                  | I                                                                   |
| 5      | -                                                                                  | I                                                                   |
| 6      | -                                                                                  | I                                                                   |
| 15     | 27                                                                                 | R                                                                   |
| 15     | 28                                                                                 | R                                                                   |
| 7      | -                                                                                  | I                                                                   |
| 8      | -                                                                                  | I                                                                   |
|        | 15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>15<br>4<br>5<br>6<br>15<br>15<br>7 | 15 0 15 1 15 2 15 3 15 4 15 5 15 6 15 7 4 - 5 - 6 - 15 27 15 28 7 - |

#### How to Make CPU?



- Typical CPU consists of 2 components
  - Datapath (Black boxes/lines) Units in the path of data
  - Control Unit (Orange boxes/lines) Units which direct operations

## Datapath

- Datapath
  - Calculation: ALU
  - Data management: Register, Memory
- ❖ Register file
  - "reset\_n" is added to a previous register file implemented in the last assignment.
- Chapter 4 in the textbook will be helpful to understand it. ©

#### Control



- Control unit
  - Decodes instruction
  - Generate the control signals for the datapath

## Assignment

- Implement a *single-cycle* TSC CPU.
  - Each instruction is executed in a single-cycle.
  - **Datapath** for 16-bit CPU (4 registers)
  - Control unit to generate control signals used in the datapath
  - This time, only five instructions (ADD, ADI, LHI, JMP, WWD)
- Datapath and control unit should be separated.
  - Build each module and connect it!
  - Control signals should transfer information between the data path and the control unit.

## Tips: Implementation

- We provide CPU skeleton code
  - Please refer to the comments for usages.

## Tips: Implementation

```
// for debuging purpose
output [`WORD_SIZE-1:0] num_inst: // number of instruction during execution
output [`WORD_SIZE-1:0] output_port: // this will be used for a "WWD" instruction
```

- output num\_inst
  - The number of instructions during execution
  - In case of single-cycle cpu, you may increment it for every posedge clock signals.
- output output\_port
  - Used only for WWD instructions
  - WWD instructions [WWD \$rs] operates output port ← \$rs.
- Testbench checks num\_inst and output\_port
  - Please refer to given testbench file.

## Tips: Implementation



- Make your own "Datapath & ControlUnit" modules
  - The datapath module should contain an ALU module (Assn1) and a register file (Assn 2)
  - The cpu module may include a Datapath module and a ControlUnit module.

## Tips: Testbench

```
// model the read process for the memory device
assign data = readM ? outputData : `WORD_SIZE'bz;
always begin
outputData = `WORD_SIZE'bz;
#`PERIODI;
forever begin
    wait (readM == 1);
    #`READ_DELAY;
    outputData = memory[address];
    inputReady = 1;
    #(`STABLE_TIME);
    outputData = `WORD_SIZE'bz;
    inputReady = 0;
end // of forever loop
end // of always block for memory read
```

- We also provide a testbench for cpu module
  - It contains memory code and in-memory instructions for test-cases.

## Testbench: Memory model

```
data == outputData only when readM is 1.
assign data = readM ? outputData : `WORD_SIZE'bz;
always begin
 outputData = `WORD_SIZE'bz;
 #"PERTOD1:
 forever begin
   wait (readM == 1);
   #"READ_DELAY:
   outputData = memory[addrews];
   inputReady = 1;
   //$display("readM: %d, data %d", outputData, data);
   #(^STABLE_TIME);
   outputData = `WORD_SIZE'bz;
   inputReady = 0;
 end // of forever loop
end // of always block for memory ead
   ₩ readM

⅓ inputReady

                                       XOX
   🕶 outputData[15:0]
                                                      ZZZZ
   🔫 data[15:0]
   🛂 instruction [15:0]
                                                     6303
```

## Testbench (In-memory instructions)

```
// store programs and data in the memory
initial begin

#`PERIOD1; // delay for a while
memory[0] = 16'h6000; // LHI $0, 0
memory[1] = 16'h6101; // LHI $1, 1
memory[2] = 16'h6202; // LHI $2, 2
memory[3] = 16'h6303; // LHI $3, 3
memory[4] = 16'hf01c; // WWD $0
memory[5] = 16'hf41c; // WWD $1
memory[6] = 16'hf81c; // WWD $2
memory[7] = 16'hfc1c; // WWD $3
```



Tcl console

- We provide CPU testcase code on the eTL board
  - TSC instructions in memory
  - You can modify the code to write your program.
  - You can check the result on Tcl console.
    - If you pass the test-case, then "PASS" is printed on the console.

#### TSC Simulator

- Consists of 2 components:
  - TSCassem: For TSC assembly coding
  - TSCsim: Simulating TSC assembly code
- Uploaded on the eTL board
  - Execute 'runit' batch files in each directory
  - They require Java!

#### TSC Simulator (TSCassem)





# Thank You